home *** CD-ROM | disk | FTP | other *** search
/ Chip 2007 January, February, March & April / Chip-Cover-CD-2007-02.iso / Pakiet bezpieczenstwa / mini Pentoo LiveCD 2006.1 / mpentoo-2006.1.iso / livecd.squashfs / usr / include / bits / sched.h < prev    next >
C/C++ Source or Header  |  2006-05-08  |  4KB  |  125 lines

  1. /* Definitions of constants and data structure for POSIX 1003.1b-1993
  2.    scheduling interface.
  3.    Copyright (C) 1996-1999,2001,2002,2003 Free Software Foundation, Inc.
  4.    This file is part of the GNU C Library.
  5.  
  6.    The GNU C Library is free software; you can redistribute it and/or
  7.    modify it under the terms of the GNU Lesser General Public
  8.    License as published by the Free Software Foundation; either
  9.    version 2.1 of the License, or (at your option) any later version.
  10.  
  11.    The GNU C Library is distributed in the hope that it will be useful,
  12.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  13.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  14.    Lesser General Public License for more details.
  15.  
  16.    You should have received a copy of the GNU Lesser General Public
  17.    License along with the GNU C Library; if not, write to the Free
  18.    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  19.    02111-1307 USA.  */
  20.  
  21. #ifndef __need_schedparam
  22.  
  23. #ifndef _SCHED_H
  24. # error "Never include <bits/sched.h> directly; use <sched.h> instead."
  25. #endif
  26.  
  27.  
  28. /* Scheduling algorithms.  */
  29. #define SCHED_OTHER    0
  30. #define SCHED_FIFO    1
  31. #define SCHED_RR    2
  32.  
  33. #ifdef __USE_MISC
  34. /* Cloning flags.  */
  35. # define CSIGNAL       0x000000ff /* Signal mask to be sent at exit.  */
  36. # define CLONE_VM      0x00000100 /* Set if VM shared between processes.  */
  37. # define CLONE_FS      0x00000200 /* Set if fs info shared between processes.  */
  38. # define CLONE_FILES   0x00000400 /* Set if open files shared between processes.  */
  39. # define CLONE_SIGHAND 0x00000800 /* Set if signal handlers shared.  */
  40. # define CLONE_PTRACE  0x00002000 /* Set if tracing continues on the child.  */
  41. # define CLONE_VFORK   0x00004000 /* Set if the parent wants the child to
  42.                      wake it up on mm_release.  */
  43. # define CLONE_PARENT  0x00008000 /* Set if we want to have the same
  44.                      parent as the cloner.  */
  45. # define CLONE_THREAD  0x00010000 /* Set to add to same thread group.  */
  46. # define CLONE_NEWNS   0x00020000 /* Set to create new namespace.  */
  47. # define CLONE_SYSVSEM 0x00040000 /* Set to shared SVID SEM_UNDO semantics.  */
  48. # define CLONE_SETTLS  0x00080000 /* Set TLS info.  */
  49. # define CLONE_PARENT_SETTID 0x00100000 /* Store TID in userlevel buffer
  50.                        before MM copy.  */
  51. # define CLONE_CHILD_CLEARTID 0x00200000 /* Register exit futex and memory
  52.                         location to clear.  */
  53. # define CLONE_DETACHED 0x00400000 /* Create clone detached.  */
  54. # define CLONE_UNTRACED 0x00800000 /* Set if the tracing process can't
  55.                       force CLONE_PTRACE on this clone.  */
  56. # define CLONE_CHILD_SETTID 0x01000000 /* Store TID in userlevel buffer in
  57.                       the child.  */
  58. # define CLONE_STOPPED    0x02000000 /* Start in stopped state.  */
  59. #endif
  60.  
  61. /* The official definition.  */
  62. struct sched_param
  63.   {
  64.     int __sched_priority;
  65.   };
  66.  
  67. __BEGIN_DECLS
  68.  
  69. /* Clone current process.  */
  70. #ifdef __USE_MISC
  71. extern int clone (int (*__fn) (void *__arg), void *__child_stack,
  72.           int __flags, void *__arg) __THROW;
  73. #endif
  74.  
  75. __END_DECLS
  76.  
  77. #endif    /* need schedparam */
  78.  
  79. #if !defined __defined_schedparam \
  80.     && (defined __need_schedparam || defined _SCHED_H)
  81. # define __defined_schedparam    1
  82. /* Data structure to describe a process' schedulability.  */
  83. struct __sched_param
  84.   {
  85.     int __sched_priority;
  86.   };
  87. # undef __need_schedparam
  88. #endif
  89.  
  90.  
  91. #if defined _SCHED_H && !defined __cpu_set_t_defined
  92. # define __cpu_set_t_defined
  93. /* Size definition for CPU sets.  */
  94. # define __CPU_SETSIZE    1024
  95. # define __NCPUBITS    (8 * sizeof (__cpu_mask))
  96.  
  97. /* Type for array elements in 'cpu_set'.  */
  98. typedef unsigned long int __cpu_mask;
  99.  
  100. /* Basic access functions.  */
  101. # define __CPUELT(cpu)    ((cpu) / __NCPUBITS)
  102. # define __CPUMASK(cpu)    ((__cpu_mask) 1 << ((cpu) % __NCPUBITS))
  103.  
  104. /* Data structure to describe CPU mask.  */
  105. typedef struct
  106. {
  107.   __cpu_mask __bits[__CPU_SETSIZE / __NCPUBITS];
  108. } cpu_set_t;
  109.  
  110. /* Access functions for CPU masks.  */
  111. # define __CPU_ZERO(cpusetp) \
  112.   do {                                          \
  113.     unsigned int __i;                                  \
  114.     cpu_set_t *__arr = (cpusetp);                          \
  115.     for (__i = 0; __i < sizeof (cpu_set_t) / sizeof (__cpu_mask); ++__i)      \
  116.       __arr->__bits[__i] = 0;                              \
  117.   } while (0)
  118. # define __CPU_SET(cpu, cpusetp) \
  119.   ((cpusetp)->__bits[__CPUELT (cpu)] |= __CPUMASK (cpu))
  120. # define __CPU_CLR(cpu, cpusetp) \
  121.   ((cpusetp)->__bits[__CPUELT (cpu)] &= ~__CPUMASK (cpu))
  122. # define __CPU_ISSET(cpu, cpusetp) \
  123.   (((cpusetp)->__bits[__CPUELT (cpu)] & __CPUMASK (cpu)) != 0)
  124. #endif
  125.